#include <cstdio>
#include <algorithm>
#include <cstring>
#include <queue>
//#define _clr(x,a) memset(x,a,sizeof(x))
using namespace std;
const int N=1e5+10;
const int M=1e5+50;
const int INF=0x3f3f3f3f;
int n,m;
int x;
int head[N];
int tot;
int dep[N];
int s,t;
int cur[N];
struct Edge{
    int v,w,next;
}edge[M];
void init(){
    tot=0;
    memset(head,-1,sizeof(head));
}
void addEdge(int u,int v,int w){
    edge[tot]=Edge{v,w,head[u]};
    head[u]=tot++;
    edge[tot]=Edge{u,0,head[v]};
    head[v]=tot++;
}
bool bfs(){
    queue<int> q;
    memset(dep,0,sizeof(dep));
    dep[s]=1;
    q.push(s);
    while(!q.empty()){
        int u=q.front();
        q.pop();
        for(int i=head[u];i!=-1;i=edge[i].next){
            int v=edge[i].v;
            int w=edge[i].w;
            if(w>0 && dep[v]==0){
                dep[v]=dep[u]+1;
                q.push(v);
            }
        }
    }
    return dep[t]!=0;
}
int dfs(int u,int flow){
    if(u==t){
        return flow;
    }
    for(int &i=cur[u];i!=-1;i=edge[i].next){
        int v=edge[i].v;
        int w=edge[i].w;
        if(dep[v]==dep[u]+1 && w!=0){
            int dis=dfs(v,min(w,flow));
            if(dis>0){
                edge[i].w-=dis;
                edge[i^1].w+=dis;
                return dis;
            }
        }
    }
    return 0;
}
int dinic(){
    int ans=0;
    while(bfs()){
        for(int i=0;i<=t;i++){
            cur[i]=head[i];
        }
        while(int d=dfs(s,INF)){
            ans+=d;
        }
    }
    return ans;
}
int dx[]={-1,1,0,0};
int dy[]={0,0,-1,1};
int main(void){
    while(~scanf("%d%d",&n,&m)){
        init();
        s=n*m;
        t=n*m+1;
        int sum=0;
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                scanf("%d",&x);
                if((i+j)%2){
                    addEdge(s,i*m+j,x);
                    if(i>0){
                        addEdge(i*m+j,(i-1)*m+j,INF);
                    }
                    if(i<n-1){
                        addEdge(i*m+j,(i+1)*m+j,INF);
                    }
                    if(j>0){
                        addEdge(i*m+j,i*m+j-1,INF);
                    }
                    if(j<m-1){
                        addEdge(i*m+j,i*m+j+1,INF);
                    }
                }
                else{
                    addEdge(i*m+j,t,x);
                }
                sum+=x;
            }
        }
        int ans=dinic();
        printf("%d\n",sum-ans);
    }
    return 0;
}